//dp[i]：偷i位置的房子的最高金额
class Solution {
public:
    int rob(vector<int>& nums) {
        int n = nums.size();
        if (n == 1)
            return nums[0];

        vector<int> dp(n, 0);
        dp[0]=  nums[0], dp[1] = max(nums[0], nums[1]);

        for (int i = 2; i < n; i++)
            dp[i] = max(dp[i - 1], nums[i] + dp[i - 2]);

        return max(dp[n - 1], dp[n - 2]);
    }
};